import { PageContainer } from '@ant-design/pro-components';
import React, {useEffect, useState} from 'react';
import {Button, Card, Descriptions, Divider, Form, message,} from "antd";
import {
  getInterfaceInfoByIdUsingGet, invokeInterfaceInfoUsingPost,
} from "@/services/yangapi_backend/interfaceInfoController";
import {useParams} from "react-router";
import TextArea from "antd/es/input/TextArea";


/**
 * 主页
 * @constructor
 */
const Index: React.FC = () => {
  const [loading, setLoading] = useState(false);
  const [data, setData] = useState<API.InterfaceInfo>();
  const params  = useParams();
  const [invokeRes,setInvokeRes] = useState<any>();
  const [invokeLoading,setInvokeLoading] = useState(false);

  const loadData = async () => {
    if(!params.id){
      message.error("参数不存在");
      return ;
    }
      setLoading(true);
      try {
        const res = await getInterfaceInfoByIdUsingGet({
          id: Number(params.id)
        });
        setData(res.data);
  } catch (error: any) {
    message.error('请求失败' + error.message)
  }
  setLoading(false);
};


  useEffect(() => {
    loadData();
  },[]);

  const onFinish = async (values: any) => {
// 检查是否存在接口id
    if (!params.id) {
      message.error('接口不存在');
      return;
    }
    setInvokeLoading(true);
    try {
      // 发起接口调用请求，传入一个对象作为参数，这个对象包含了id和values的属性，
      // 其中，id 是从 params 中获取的，而 values 是函数的参数
      const  res = await invokeInterfaceInfoUsingPost({
        id: params.id,
        ...values,
      });
      setInvokeRes(res.data);
      message.success('请求成功');
    } catch (error: any) {
      message.error('操作失败，' + error.message);
    }
    setInvokeLoading(false);
  };


  return (
    <PageContainer title= "查看接口文档">
      <Card>
        {
          data ?  (
            <Descriptions title={data.name} column={1} >
            <Descriptions.Item label="接口状态">{data.status ? '正常':'关闭'}</Descriptions.Item>
            <Descriptions.Item label="描述">{data.description}</Descriptions.Item>
            <Descriptions.Item label="请求地址">{data.url}</Descriptions.Item>
            <Descriptions.Item label="请求方法">{data.method}</Descriptions.Item>
            <Descriptions.Item label="请求参数">{data.requestParams}</Descriptions.Item>
            <Descriptions.Item label="请求头">{data.requestHeader}</Descriptions.Item>
            <Descriptions.Item label="响应头">{data.responseHeader}</Descriptions.Item>
            <Descriptions.Item label="更新时间">{data.updateTime}</Descriptions.Item>
            <Descriptions.Item label="创建时间">
            {data.createTime}
            </Descriptions.Item>
          </Descriptions>
          ) : (<>接口不存在</>
          )}
      </Card>
      <Divider/>
      <Card title="在线测试">
        <Form
          name="invoke"
          onFinish={onFinish}
          layout={"vertical"}
        >
          <Form.Item
            label="请求参数"
            name="userRequestParams"
          >
            <TextArea />
          </Form.Item>

          <Form.Item wrapperCol={{ span: 16 }}>
            <Button type="primary" htmlType="submit">
              调用
            </Button>
          </Form.Item>
        </Form>
      </Card>
      <Divider/>
      <Card title="返回结果" loading={invokeLoading}>
        {invokeRes}
      </Card>
    </PageContainer>
  );
};

export default Index;
